php - 传递的数组丢失除第一个元素以外的所有元素
全部标签 我需要一个函数来返回字符串中正则表达式的所有匹配项和找到匹配项的位置(我想突出显示字符串中的匹配项)。有一个String#match返回MatchData,但只针对第一个匹配项。有没有比类似的方法更好的方法matches=[]beginmatch=str.match(regexp)breakunlessmatchmatches 最佳答案 如果您只需要遍历MatchData对象,您可以在扫描block中使用Regexp.last_match,例如:string.scan(regex)domatch_data=Regexp.last_m
执行此操作最巧妙、最像Ruby的方法是什么?[1,3,10,5].diff应该产生[2,7,-5]即一阶差分数组。我想出了一个解决方案,我将在下面添加它,但它需要ruby1.9并且不是那么圆滑。还有什么可能? 最佳答案 我喜欢这种函数式风格:moduleEnumerabledefdiffeach_cons(2).map{|pair|pair.reverse.reduce:-}endend编辑:我刚刚意识到reverse是完全没有必要的。如果这是一种函数式语言,我会使用模式匹配,但Ruby不支持模式匹配。但是,它确实支持解构绑定(
这个周末我一直在研究Liquid模板引擎,我想知道以下是否可行。假设我在Blog模型中有一个latest_posts方法,我可以将一个整数传递给该方法以获取最新的N篇文章。是否可以在液体模板中使用该方法?例如:classBloghas_many:postsdeflatest_posts(n)posts.latest(n)#usinganamedscopeenddefto_liquid(*args){'all_posts'=>posts.all,#allowsmetouse{%forpostsinblog.all_posts%}'last_post'=>post.last,#allows
-@subjects.eachdo|s|%tr%td=s.position%td=s.name%td=s.visible?"Yes":"No"%td=s.pages.size%td=link_to("Show",{:action=>"show",:id=>s.id},:class=>"actionshow")=link_to("Edit",{:action=>"edit",:id=>s.id},:class=>"actionedit")=link_to("Delete",{:action=>"delete",:id=>s.id},:class=>"actiondelete")错误消息:
有人知道如何在SeleniumRubyWebdriver中将鼠标悬停在元素上吗?我的代码是这样的:el=driver.find_element(:css=>"#foo")driver.move_toel#HowdoItriggeramouseovereventonthiselement?我在Linux32位的Firefox中使用selenium-webdrivergem。 最佳答案 我使用了driver.action.move_to(el).perform,它与其他答案略有不同,所以我想为了完整起见我会把它包括在内。
我有Ubuntu11.10,正在使用rvm和ruby1.9.2。我完全按照这个来安装Ruby:http://blog.sudobits.com/2011/10/27/how-to-install-ruby-on-rails-in-ubuntu-11-10/我用生成文档rvmdocsgenerate这似乎适用于一次性终端session,但一旦我退出并重新开始,我必须再次生成文档,否则我会收到NothingisKnown错误这需要很长时间,所以我宁愿不必在每次启动终端session时都生成文档。我可以做些什么来使文档永久可用吗?肯定有与此类似的问题——但我对生成文档或使用它们没有问题,
我想知道如何使用ruby中的范围生成以下数组["00","00","01","01","02","02",......"10","10"]我想将每个元素重复两次,这就是我要寻找答案的部分。我可以生成单个元素,如下所示("00".."10").to_a我知道我可以使用循环等来做到这一点,但我正在寻找一种更简单的单行代码谢谢 最佳答案 使用Array#zip和Array#flatten:a=("00".."10").to_aa.zip(a).flatten#["00","00","01","01","02","02","03","0
这个有效:f=File.new("myfile").readlinesf[0]#=>"line1"f[21]#=>"line22"但是如果我有一个非常大的文件,并且只需要读取几行怎么办?是否可以在不将文件加载到数组的情况下查找特定行并在Ruby中读取它们?我理解IO流,其中(就像在stdin的情况下)您不能随机搜索流。当然,必须有一种方法可以在不加载整个文件的情况下执行此操作。 最佳答案 不要忽略IO类。IO::foreach是返回枚举器的方法之一,可以延迟计算。IO#each_line也是将返回枚举器的另一个。在Ruby2.0中,
我有两个数组,一个包含数据,一个包含索引。我想知道是否有一些好的方法可以删除indexes中给定位置的data中的元素。我可以做简单的迭代,但我想知道最短的方法是什么:data=['a','b','c','a','b','c','a','b','c']indexes=[2,5,8]//somecodeheredata中的元素在索引恰好与数组索引中的数字重合时消失。它应该看起来像这样:['a','b','a','b','a','b'] 最佳答案 data.values_at(*data.each_index.to_a-indexes)
例如,要返回我可以写的第10,000个质数:require'prime'Prime.first(10000).last#=>104729但是创建一个巨大的中间数组,只是为了检索它的最后一个元素感觉有点麻烦。鉴于Ruby是一种如此优雅的语言,我本以为会是这样的:Prime.at(9999)#=>104729但是没有Enumerable#at。上面的解决方法是有意的还是有更直接的方法来获取Enumerable的第n个元素? 最佳答案 我能想到的与假设的at方法最接近的是drop,它会跳过指定数量的元素。它试图返回一个实际的数组,所以如果